// 引入用户集合的构造函数
const { User, validateUser } = require('../../model/user');
// 引入加密模块
const bcrypt = require('bcrypt');

module.exports = async(req, res, next) => {

  try {
    await validateUser(req.body)
  } catch(e) {
    // 验证没有通过
    // e.message
    // 重定向回用户添加页面
    // return res.redirect(`/admin/user-edit?message=${e.message}`);
    // JSON.stringify() 将对象数据类型转换为字符串数据类型
    return next(JSON.stringify({ path: '/admin/user-edit', message: e.message }));
  }

  // 根据邮箱地址查询用户是否存在
  let user = await User.findOne({email: req.body.email});
  // 如果用户已经存在，邮箱地址已经被别人占用
  if (user) {
    // 重定向回用户添加页面
    // return res.redirect(`/admin/user-edit?message=邮箱地址已经被占用`);
    return next(JSON.stringify({ path: '/admin/user-edit', message: '邮箱地址已经被占用' }));
  }

  // 对密码进行加密处理
  // 生成随机字符串
  const salt = await bcrypt.genSalt(10);
  // 加密
  const password = await bcrypt.hash(req.body.password, salt);
  // 替换密码
  req.body.password = password;

  // 将用户信息添加到数据库中
  await User.create(req.body);

  // 将页面重定向到用户列表页面
  res.redirect('/admin/user');

}